+Mon Nov 29 17:51:51 2004 Søren Sandmann <sandmann@redhat.com>
+
+ * gtk/gtksequence.c (_gtk_sequence_sort_changed): If the item is
+ already in the right place, don't move it. Bug #157670.
+
+ * gtk/gtksequence.c (already_in_place): New function
+
Mon Nov 29 17:28:53 2004 Søren Sandmann <sandmann@redhat.com>
* gtk/gtksequence.c (_gtk_sequence_sort): Take nodes in reverse
+Mon Nov 29 17:51:51 2004 Søren Sandmann <sandmann@redhat.com>
+
+ * gtk/gtksequence.c (_gtk_sequence_sort_changed): If the item is
+ already in the right place, don't move it. Bug #157670.
+
+ * gtk/gtksequence.c (already_in_place): New function
+
Mon Nov 29 17:28:53 2004 Søren Sandmann <sandmann@redhat.com>
* gtk/gtksequence.c (_gtk_sequence_sort): Take nodes in reverse
+Mon Nov 29 17:51:51 2004 Søren Sandmann <sandmann@redhat.com>
+
+ * gtk/gtksequence.c (_gtk_sequence_sort_changed): If the item is
+ already in the right place, don't move it. Bug #157670.
+
+ * gtk/gtksequence.c (already_in_place): New function
+
Mon Nov 29 17:28:53 2004 Søren Sandmann <sandmann@redhat.com>
* gtk/gtksequence.c (_gtk_sequence_sort): Take nodes in reverse
+Mon Nov 29 17:51:51 2004 Søren Sandmann <sandmann@redhat.com>
+
+ * gtk/gtksequence.c (_gtk_sequence_sort_changed): If the item is
+ already in the right place, don't move it. Bug #157670.
+
+ * gtk/gtksequence.c (already_in_place): New function
+
Mon Nov 29 17:28:53 2004 Søren Sandmann <sandmann@redhat.com>
* gtk/gtksequence.c (_gtk_sequence_sort): Take nodes in reverse
return _gtk_sequence_node_find_by_pos (ptr, new_pos);
}
+static gboolean
+already_in_place (GtkSequencePtr ptr,
+ GCompareDataFunc cmp_func,
+ gpointer data)
+{
+ SortInfo info;
+
+ info.cmp = cmp_func;
+ info.data = data;
+
+ if (node_compare (_gtk_sequence_node_prev (ptr), ptr, &info) <= 0 &&
+ node_compare (_gtk_sequence_node_next (ptr), ptr, &info) >= 0)
+ {
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
void
_gtk_sequence_sort_changed (GtkSequencePtr ptr,
GCompareDataFunc cmp_func,
{
GtkSequence *seq;
-
+
+ g_return_if_fail (ptr != NULL);
g_return_if_fail (!ptr->is_end);
+
+ if (already_in_place (ptr, cmp_func, cmp_data))
+ return;
seq = _gtk_sequence_node_get_sequence (ptr);
_gtk_sequence_unlink (seq, ptr);